


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>封装_简易axios-获取省份列表</title>
</head>
<body>
    <p class="city">

    </p>

    <script>

        /**
         * 目标：封装_简易axios函数_获取省份列表
         * 1;定义myAxios函数，接收配置对象，返回Promise对象
         * 2：发起XHR请求，默认请求方法为GET
         * 3：调用成功/失败的处理程序
         * 4: 使用myAxios函数，获取省份列表展示
         */
        function myAxios(config) {
            return  new Promise((resolve,reject)=>{
                const  xhr = new XMLHttpRequest()
     
                xhr.open(config.method || 'get',config.url)
        
                xhr.addEventListener("loadend",function () {
                    // xhr如何判断响应成功还是失败的？
                    // 2xx开头的都是成功响应状态码
                    if (xhr.status>=200 && xhr.status < 300) {
                        resolve(JSON.parse(xhr.response))
                    } else {
                        reject(new Error(xhr.response))
                    }           
                })

            xhr.send()

            })
        }

        myAxios({
            url:"http://hmajax.itheima.net/api/province"
        }).then(res=>{
            console.log(res);           
            document.querySelector('.city').innerHTML = res.list.join("<br />")

        }).catch(err=>{
            // 详细打印
            console.dir(err)
            document.querySelector('.city').innerHTML = err.message;
        })
        
    </script>

</body>
</html>